草庐IT

C++ unique_ptr 和映射

全部标签

c++ - 我可以将新的 std::tuple 放入内存映射区域,然后再读回吗?

我有一些打包的结构,我将把它们写入内存映射文件。它们都是POD。为了适应我正在做的一些通用编程,我希望能够编写一个std::tuple几个打包结构。我担心写一个std::tuple的成员到我映射区域的地址,然后将该地址转换回std::tuple会坏掉的。我写了一个小示例程序,它似乎可以工作,但我担心我有未定义的行为。这是我的结构:structFoo{charc;uint8_tpad[3];inti;doubled;}__attribute__((packed));structBar{inti;charc;uint8_tpad[3];doubled;}__attribute__((pac

c++ - 从同一个指针构造两个 shared_ptr 对象

我有一个来自“C++标准库扩展”的问题:Exercise6IsaidinSection2.4.2thatyoushouldn'tconstructtwoshared_ptrobjectsfromthesamepointer.Thedangeristhatbothshared_ptrobjectsortheirprogenywilleventuallytrytodeletetheresource,andthatusuallyleadstotrouble.Infact,youcandothisifyou'recareful.It'snotparticularlyuseful,butwrit

c++ - 发布 boost::ptr_vector,不匹配文档

我正在使用boost1.37,我正在尝试使用boost::ptr_vector,并转移它的所有权,以便我可以从函数中返回它。查看boost文档(http://www.boost.org/doc/libs/1_36_0/libs/ptr_container/doc/tutorial.html#new-functions)std::auto_ptr>get_zoo(){boost::ptr_dequeresult;...returnresult.release();//giveupownership}...boost::ptr_dequeanimals=get_zoo();我试过:#inc

c++ - 在 boost::python 中公开 boost::scoped_ptr

我收到一个编译错误,说scoped_ptr的复制构造函数是私有(private)的,代码片段如下:classa{};structs{boost::scoped_ptrp;};BOOST_PYTHON_MODULE(module){class_("s");}虽然这个例子适用于shared_ptr。如果有人知道答案,那就太好了。谢谢 最佳答案 boost::scoped_ptr的语义禁止复制,而shared_ptr旨在被复制。您得到的错误是编译器告诉您某些代码(宏扩展?)正在尝试复制scoped_ptr但库不允许进行复制。

c++ - 使用 STL/Boost/Lambdas 调整映射迭代器

考虑以下非工作代码:typedefmapmymap;mymapm;for(inti=1;i(),3));我正在尝试从这张map中删除元素.second.这显然没有写对。我如何正确地写这个:使用bind的标准STL函数对象和技术+less但无需编写自定义仿函数提升.绑定(bind)C++0xLambda我知道我不是erase荷兰国际集团的元素。别担心;我只是简化要解决的问题。 最佳答案 我不确定如何仅使用STL绑定(bind)器来执行此操作,但我认为您的主要问题是传递给remove的仿函数的内容是什么?不只是一个int但是一个pair

c++ - 递归STL映射

我正在尝试制作一棵map树(或者只是将一个map的值指向另一个map),但我不太确定如何处理这个问题。我发现了一个关于这个的讨论:http://bytes.com/topic/c/answers/131310-how-build-recursive-map但我对那里发生的事情有点困惑。比如我的key是一个char,我的value是下一个map。这是假设的声明:map>>>>>>>>>root_map; 最佳答案 也许你在想这样的事情:#include#includetemplatestructTree{typedefstd::map

c++ - auto_ptr 和 dynamic_pointer_cast

如果我想将dynamic_cast与shared_ptr一起使用,我可以使用dynamic_pointer_cast。如果我想转换auto_ptr,我该用什么?我假设如下所示。structB:A{};...auto_ptrbase(...);auto_ptrderive=dynamic_pointer_cast(base);我正在为shared_ptr使用boost 最佳答案 auto_ptrbase(...);if(B*query=dynamic_cast(base.get())){//takeownershipbase.rele

c++ - 按值返回由互斥量保护的 shared_ptr 是否安全?

这是一个代码示例:classA{boost::mutexa_mutex;boost::shared_ptra;boost::shared_ptrclone_a(void){boost::lock_guardlock(a_mutex);returna;}};建议boost::shared_ptr对A::a的复制构造函数调用将在boost::lock_guard析构函数调用之前尽管有编译器优化。那么,调用A::clone_a()安全吗? 最佳答案 如果您所说的“安全”是指您不会在a上发生数据竞争,那么是的。正如你所说。但是,正如您可能知

c++ - 使用非标准键映射。怎么了?

我正在尝试编写std::map容器,其中键有2个值。这是示例:#include#includeusingnamespacestd;structKey{inti1;inti2;structComparator{booloperator()(constKey&k1,constKey&k2){if(k1.i1tree;for(inti=0;i::iteratorit=tree.find(key);if(it==tree.end()){coutsecond它告诉我“没有找到任何东西”。我哪里弄错了?我应该如何编写Comparator才能使其正常工作?谢谢。 最佳答案

c++ - 我如何在 void* 和 boost shared_ptr 之间进行转换

我有这些行:typedefboost::shared_ptrA_SPtr;void*f(void*var){...我希望能够做这样的事情:A_SPtrinstance=(void*)(var);我该怎么做?另外,我怎样才能将意义从shared_ptr转换为void*? 最佳答案 只需将指针转换为指向和来自void*的共享指针。shared_ptr到void*:f(reinterpret_cast;(&A_SPtr));void*回到shared_ptr:A_SPtrinstance=*reinterpret_cast(boost::